/*
 Problem Description
有一头母牛，它每年年初生一头小母牛。每头小母牛从第四个年头开始，每年年初也生一头小母牛。
请编程实现在第n年的时候，共有多少头母牛？
Input
输入数据由多个测试实例组成，每个测试实例占一行，包括一个整数n(0<n<55)，n的含义如题目中描述。
n=0表示输入数据的结束，不做处理。
Output
对于每个测试实例，输出在第n年的时候母牛的数量。
每个输出占一行。
Sample Input
2
4
5
0
Sample Output
2
4
6
 */
package com.yuan.algorithms.training20150719;

import java.util.Scanner;

public class 母牛的故事 {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while(sc.hasNext()) {
			int n = sc.nextInt();
			if (n==0) {
				break;
			}
			long[] arr = new long[4];
			arr[0] = 1;//成年的牛
			arr[1] = 0;
			arr[2] = 0;
			arr[3] = 0;//3年的牛
			for (int i = 1; i < n; i++) {
				arr[0] = arr[0]+arr[3];
				arr[3] = arr[2];
				arr[2] = arr[1];
				arr[1] = arr[0];
			}
			System.out.println(arr[0]+arr[1]+arr[2]+arr[3]);
		}
	}

}
